package com.sky.mapper;

import com.github.pagehelper.Page;
import com.sky.annotation.AutoFill;
import com.sky.dto.SetmealPageQueryDTO;
import com.sky.entity.Setmeal;
import com.sky.enumeration.OperationType;
import com.sky.vo.SetmealVO;
import org.apache.ibatis.annotations.Delete;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;

import java.util.List;

@Mapper
public interface SetmealMapper {
    @Select("select count(id) from setmeal where category_id = #{id}")
    Integer queryById(Long id);

    @AutoFill(value = OperationType.INSERT)
    void insert(Setmeal setmeal);

    Page<SetmealVO> select(SetmealPageQueryDTO setmealPageQueryDTO);




    @Select("select * from setmeal where id= #{id}")
    Setmeal selectById(Long id);

    @Delete("delete from  setmeal where id=#{id}")
    void deleteById(Long id);


    @AutoFill(value = OperationType.UPDATE)
    void update(Setmeal setmeal);


    @Select("select s.*,c.name categoryName from setmeal s left join category c on s.category_id = c.id where s.id = #{id}")
    Setmeal selectWithCategoryById(Long id);

    @Select("select * from setmeal where category_id = #{categoryId}")
    List<Setmeal> selectByCategoryId(Long categoryId);
}
